The
NIST has published a white paper on the issues surrounding electronic voting. They conclude that purely electronic systems (a DRE, or direct record electronic, system) are not viable. This conclusion is based on two observations: the lack of any viable audit mechanism to independently verify electronic ballots and tallies, and the difficulty in testing any such system to verify its reliability and accuracy. The primary fear is that a lone programmer could rig an election, and without an audit trail or the ability to test the system, this rigging would be undetectable.
First of all, I don't really see how you could rig an election. The software that would be written would be generic, applicable to any election, not specific to any one election. The state election's board, when deploying the software, would provide the specific ballot information for that election in some sort of configuration file. Then in the next election, a new configuration file would be provided. Therefore, the programmer(s) writing the software would have no way of knowing what specific election the software is being used in, so how would the programmer be able to corrupt any specific election?
Second, I don't really get the testing point. The paper states, "NIST and STS do not know how to write testable requirements to satisfy that the software in a DRE is correct." Um, how about I set up a ballot and run some large number of votes through the system and then verify that the tallying results agree with what I put in? If the software has some rigging built in, then the final tallies won't agree with what was entered. This really isn't all that hard. I and my project teams test more complicated software every day. My test case is that if I put in 5 votes for Hillary Clinton, then the tally comes out with 5 votes for Hillary Clinton. Is it really that hard? And are the testing requirements any different for a DRE than they would be for, say, a system where paper ballots are electronically scanned?
The audit concerns are legitimate. But are they really any different than those in finance, which is becoming increasingly electronic? The NIST paper points to this domain and its use of paper receipts to provide the audit trail. But as the economy goes more and more electronic, more and more money is being traded without a paper receipt. If I buy a video game from Amazon, I don't get a paper receipt for the transaction. What do I get? An email with a summary of the purchase. In other words, an independent electronic recording of the transaction.
With that in mind, I think the independent verification (IV) solution mentioned in the paper (and declared immature in design at this point) is the best approach. This may be over (or under) engineered, but here's how I would design the system. There would be three independent software components: the voting component, an audit component, and the recording and tallying component. NIST would define the software interfaces between these components and the state election boards would require different vendors for each to reduce the possibility of collusion. The voter would cast his or her ballot in the voting component, which would have a touch screen or something. The voting component would notify, using the interfaces specified by NIST, both the audit and recording components of the vote it has received. The audit component present the vote to the voter for confirmation. The audit component would notify the recording component that the ballot has been verified or rejected. If the ballot is verified, the audit component would independently record the vote for later audit purposes. The recording component would only record ballots that have been verified. If there are later concerns about the tally, the votes recorded by the recording component could be compared with those recorded by audit.
That could be total crap, I don't know. But it would provide multiple, independent electronic audit trails of the ballots, and would separate the different pieces of the software (particularly if the state requires that the vendors be independent), making it difficult to propagate rigged results through it.